@use "lib/viewport";

#topic-footer-buttons {
  display: flex;
  flex-direction: column;
  gap: var(--below-topic-margin);
  max-width: calc(
    var(--topic-avatar-width) + var(--topic-body-width) +
      var(--topic-body-width-padding) * 2
  );

  html.anon & {
    align-items: end;
  }

  .topic-footer-main-buttons {
    display: flex;
    gap: 0.5rem;

    @include viewport.until(sm) {
      gap: 0.75rem;
      justify-content: space-between;

      .btn,
      .topic-notifications-button .btn,
      .pinned-button .btn {
        font-size: var(--font-up-1-rem);
      }

      html:not(.anon) & {
        width: 100%;

        .d-button-label {
          display: none;
        }

        .d-icon {
          margin-right: 0;
        }
      }
    }

    &__actions {
      display: flex;
      gap: 0.75rem;
      flex-wrap: wrap;

      @include viewport.from(sm) {
        gap: 0.5rem;
      }
    }

    .bookmark.bookmarked {
      .d-icon-discourse-bookmark-clock,
      .d-icon-bookmark {
        color: var(--tertiary);
      }
    }

    .create {
      align-self: flex-start;
    }
  }

  .pinned-button,
  .topic-notifications-button {
    .text {
      color: var(--primary-high);
    }

    @include viewport.until(sm) {
      .selected-name .name {
        display: none;
      }
    }

    .reason {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      margin: 0;

      details,
      button {
        flex-shrink: 0;
      }
    }
  }
}

.with-topic-progress {
  position: sticky;
  bottom: calc(env(safe-area-inset-bottom) + var(--composer-height, 0px));
  z-index: z("timeline");
  pointer-events: none; // the wrapper can block mobile controls

  > * {
    pointer-events: auto; // this unsets the above rule so the child elements are interactive
  }

  .composer-open:not(.composer-has-preview) & {
    position: fixed;
    max-width: var(--composer-max-width--hide-preview);
    width: 100%;
    left: 0;
    right: 0;
    margin-inline: auto;
  }

  @media screen and (min-width: $reply-area-max-width) {
    .composer-open:not(.composer-has-preview) .has-sidebar-page & {
      max-width: calc(
        var(--composer-max-width--hide-preview) + var(--d-sidebar-width)
      );
    }
  }
}

#topic-progress-wrapper {
  display: flex;
  justify-content: flex-end;
  overflow: hidden;

  &.docked {
    .toggle-admin-menu {
      display: none;
    }
  }

  .btn {
    border: 0;
  }

  #topic-progress {
    position: relative;
    background-color: var(--secondary);
    color: var(--tertiary);
    padding: 0.5rem 1em;
    border: 1px solid var(--tertiary-low);

    /* as a big ol' click target, don't let text inside be selected */
    @include unselectable;

    .nums {
      display: flex;
      gap: 0.3rem;
      align-items: center;
      height: 100%;
      position: relative;
      z-index: z("base");
      font-size: var(--font-up-1);
      font-weight: bold;
    }

    .d-icon {
      position: absolute;
      right: 8px;
      bottom: 9px;
      z-index: z("base");
    }

    .bg {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      width: var(--progress-bg-width, 0);
      background-color: var(--tertiary-low);
    }
  }
}
